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(54) Method for accessing internet applications from home network devices 

(57) The invention concerns a communication 

method in a home network comprising at least two / — 23 
devices connected to a communication bus, character- 
ized in that, a first device including an internet applica- 
tion and a second device including means for 
connecting to the internet, said second device being 
able to manage at least one internet application proto- 
col, said method comprises the steps of: 



sending a request from said first device to said sec- 
ond device for opening a connection between said 
first and second devices, wherein said request con- 
tains an internet application protocol identifier to 
identity the internet application protocol to be used 
over said connection; 

sending and internet protocol request under the for- 
mat of said internet application protocol from said 
first device to said second device; 
forwarding said internet protocol request from said 
second device to an internet server; 
upon receipt, transferring an response from said 
internet server to said first device through said sec- 
ond device over said communication bus. 




Fig. 2 



J" The invention also concerns a network and a 

^ device for implementing the method above. 
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Description 

[0001] The invention concerns a communication method in a home network, in particular a HAVi-compliant network. 
It also concerns the network itself , and a device used in the implementation of the method. The invention applies among 

s others to the communication between an internet application running on a network device which may not necessarily 
have a direct access to the internet, and a device of the network which does have such an access. 
[0002] Figure 1 is a diagram of the different devices and software layers required to access internet services from a 
personal computer 1 . This computer 1 comprises an application including a user interface for interacting with a user, for 
example a WEB browser', qualified in figure 1 by the more general term WEB application*. 

10 [0003] The WEB application lies above an application protocol layer (such as HTTP (Hypertext Transfer Protocol) or 
FTP (File Transfer Protocol) or another type of protocol). The next layers are, according to the example of figure 1 , the 
TCP/UDP (Transmission Control Protocol, respectively User Data Protocol) layer, the IP (Internet Protocol) layer and 
the PPP layer. The TCP/UDP and IP layers combined are referred to as the 'IP stack*. The connection with an internet 
access provider 2 is made through modems and the public switched telephone network. The internet access provider 

15 is connected to the internet, which comprises the server 3, the latter including layers globally similar in function to those 
of computer 1 . 

[0004] A user may own a number of devices such as television receivers and personal computers which have the 
internet access functionality provided by the device 1 of figure 1 . In such a case the hardware and software required for 
providing the internet access capability is duplicated in each device. 
20 [0005] The object of the invention is a communication method in a home network comprising at least two devices con- 
nected to a communication bus, characterized in that, a first device including an internet application and a second 
device including means for connecting to the internet, said second device being able to manage at least one internet 
application protocol, said method comprises the steps of: 

25 - sending a request from said first device to said second device for opening a connection between said first and sec- 
ond devices, wherein said request contains an internet application protocol identifier to identify the internet appli- 
cation protocol to be used over said connection; 

sending an internet protocol request under the format of said internet application protocol from said first device to 
said second device; 

30 - forwarding said internet protocol request from said second device to an internet server; 

upon receipt, transferring an response from said internet server to said first device through said second device over 
said communication bus. 

[0006] By including into the network a device which has the means for connecting to the internet and which at the 
35 same time possesses the means to communicate with devices (or software elements such as applications) in the net- 
work, only one device with such a capacity is required for the entire network, regardless of the number of internet- 
related applications running in devices of this network. 

[0007] Moreover, an internet application establishing an internet connection through the second device specifies itself 
the internet application protocol it wishes to use. This provides a very flexible way to use different internet application 

40 protocols within a same network. 

[0008] According to an embodiment of the invention, the inventive method includes the step of sending, by said first 
device to said second device, a request for a list of internet application protocols supported by said second device. 
[0009] The invention also concerns a home communication network comprising devices connected by a communica- 
tion bus, said network comprising at least one device including a WEB interface, said device comprising an IP stack and 

45 a connection to the internet, said at least one device comprising an application programmable interface for making said 
WEB interface accessible to software element clients of other devices in said network. 

[001 0] The invention also concerns a device in a home communication network characterized in that it comprises a 
WEB interface, said device also comprising an IP stack and a connection to the internet, said at least one device com- 
prising an application programmable interface for making said WEB interface accessible to software element clients of 
so other devices in said network. 

[0011] Other characteristics and advantages of the invention will appear through the description of a non-limiting 
embodiment of the invention, said description being made with reference to the following figures: 

figure 1 is a schematic diagram of devices and connections for accessing an internet server from a home equip- 
ss merit; 

figure 2 is a diagram of a home network according to the present invention; 

figure 3 is a diagram of the messages exchanged between the WEB client and the WEB proxy agent; 

figure 4 is a diagram of the communication between software elements for establishing a communication between 
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a WEB client software element and a WEB server via a WEB proxy agent. 

[0012] The following description uses a terminology defined in the following document, to which one should refer for 
further details: 'The HAVi Architecture - Specification of the Home AudioAfideo interoperability (HAVi) Architecture' of 
5 May 11,1 998 Version 0.8 and publicly disclosed on May 1 5, 1998 on the WEB sites of at least the following companies: 
Sony, Philips, Toshiba, Sharp and Hitachi. Explanations and definitions regarding the terminology are also given at the 
end of the present description. 

[001 3] For further information regarding HTTP, which will be taken as an example as the protocol used by the WEB 
application of the present embodiment, the document ' Hypertext Transfer Protocol / 1 .1 RFC 2068' can be used as a 
10 reference. Other protocols than HTTP may be used: FTP, SMTP, POP, IMAP and NNTP are some examples. 

[0014] An introduction to a HAVi-compliant network architecture will first be given, in order to define a number of con- 
cepts necessary for the description of the embodiment of the invention. 

[001 5] A HAVi network comprises devices which can be of four types, these devices being linked by a communication 
bus. The different device types are, ordered according to their network-related capabilities; Full Audio/Video devices 
75 (FAV devices), Intermediate Audio/Video Devices (IAV devices), Basic Audio/Video devices (BAV devices), and Legacy 
AudioA/ideo devices (LAV devices). 

[001 6] Except for the LAV- type devices, the other devices all have at least the capability of communicating with each 
other. 

[0017] FAV devices contain a runtime environment for HAVi bytecode. HAVi bytecode is a programming language in 
20 which device control modules (DCMs) or applications may be written. A FAV device may thus download DCMs from or 
for other devices which do not include this runtime environment, for example for cost reasons. 
[001 8] IAV devices do not have the capability to run HAVi bytecode, but may include resident DCMs for the control of 
other devices. 

[001 9] BAV devices are devices which either contain DCM code downloadable by a FAV device, or which are control - 
25 led by a native DCM run by an IAV device. 

[0020] LAV devices are devices which do not have any HAVi capability. These devices have their own command pro- 
tocol and require that a FAV or an IAV device act as a gateway to the HAVi network and perform the necessary control 
command translation. 

[0021 ] Each device contains a number of objects, called 'software elements' in the HAVi terminology. A control man- 
30 ager of a given function (called FCM) of a device, i.e. a software element providing an interface for controlling a specific 
functional component (e.g. tuner, display, mass storage...) of a device is one of such objects. A DCM as mentioned 
above is another one. 

[0022] Typically, a FAV device would contain a number of applications and device control applications which interact 
with the following software elements through corresponding application programmable interfaces: 

35 

a 1394 Communication Media Manager, which allows other software elements to perform asynchronous and iso- 
chronous communication over the IEEE 1394 bus; 

a Message Passing System, for exchanging messages with other software elements; 
an Event Manager for managing object state changes; 
40 - a Stream Manager for managing Audio/Video data streams between functional components, such as a tuner and 
a recording device; 

a Registry, which keeps a list of local software elements and its identifiers and manages communication with distant 
registries; 

Device Control Module Manager, for loading or deleting Device Control Modules; 
45 - a number of either resident or uploaded Device Control Modules; 
a HAVi bytecode runtime environment for executing DCMs. 

[0023] The Message Passing System allocates unique identifiers to software elements, which use these identifiers to 
register themselves with the Registry. These identifiers are called 'SEID', standing for Software Element Identifiers, and 

so comprise a device identifier and a software element handle within that device. A first software element wishing to send 
a message to a second software element will pass the SEID of this second software element as a parameter in its com- 
mand to the Message Passing System. It obtains this SEID by making an appropriate request with the local Registry 
service. Depending on whether the software element to be called is local or distant (i.e. in another device than the call- 
ing software element), the calling software element will use the whole SEID or only its software element handle part. 

55 [0024] The mapping of function calls into messages of the Message Passing System is described in detail in Chapter 
3.2.3 of the HAVi 0.8 document. The Message Passing System described in this version of the HAVi document can han- 
dle messages up to 64 Kb long. 

[0025] The French patent application FR 98051 1 0 filed on April 23, 1 998 in the name of THOMSON multimedia gives 
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additional information about the Registry and the Message Passing System. 

[0026] Figure 2 represents a HAVi-compliant home network comprising devices 20, 21 and 22 connected to a com- 
munication bus 23. The bus 23 is for example an IEEE 1394 serial bus. Device 20 is a digital television receiver, com- 
patible with the Digital Video Broadcast (DVB) standard in use in Europe or the Direct Satellite System (DSS) in use in 

5 the United States. It comprises a WEB application) i.e. a software application capable of sending and/or requesting data 
through the internet using the HTTP protocol. For the purpose of the present example, the WEB application of device 
20 is an electronic program guide (EPG) exchanging information with a given internet server. Device 22 is a personal 
computer, whose WEB application is an internet browser. Neither one of devices 20 and 22 possesses an IP stack, the 
PPP protocol layer or a modem connected to the public switched telephone network. 

io [0027] Device 21 comprises a WEB access application programming interface (WEB access API), as well as the IP 
stack, PPP protocol and a modem. Device 21 can be a FAV, a IAV or a BAV device. The functional component module 
(FCM) giving access to IP stack operation by the different WEB applications is called "Internet Proxy Agent*, or *WEB 
Proxy Agent'. It provides the WEB access application programmable interface which is the layer above the IP stack. 
[0028] According to the present example, the device 21 is a digital television decoder comprising a modem. 

15 [0029] The WEB Proxy FCM offers a sharable access to the internet. It registers upon reset or hot-plugging at the 
local Registry of device 21 , if that device is a FAV or IAV, or at the local registry of the FAV or IAV device which runs the 
Device Control Module corresponding to the WEB Proxy FCM if device 21 is of the BAV type. 

[0030] The WEB application, which can also be referred to as "WEB client', is able to detect the WEB Proxy FCM in 
the network by sending a request to its local Registry service. The local Registry dispatches the request to distant Reg- 
20 istries and collects the responses. In the case of the present embodiment, only the identifier ('SEID') of the WEB Proxy 
FCM of device 21 will be detected. 

[0031] The WEB Proxy FCM preferably supports at least several commonly used internet protocols, such as HTTP, 
FTP, NNTP, SMTP, POP or IMAP. The WEB client uses the WEB Proxy FCM application programmable protocol through 
the Message Passing System. The application programmable interface comprises the following functions: Open, Close, 
25 Send, Receive and GetCapability. 

[0032] These different functions will now be described in detail. 

[0033] The following data structures are used by the functions of the WEB Proxy FCM: 

(a) enum FileLoc {START, NEXT, END}; 
30 This data structure indicates whether the message from a producer to a consumer is the first message, an inter- 
mediate message or the last (or only) message in a sequence of messages. It is used in conjunction with the notion 
of buffer size at the WEB client or at the WEB Proxy FCM, since this buffer size, as explained later on, may cause 
a function call to be split over several messages. 

35 (b) enum ProtocolType { HTTP, FTP, SMTP, POP3, IMAP4, NNTP, WAIS}; 

This data structure indicates the list of WEB application protocols the WEB proxy FCM may support. 

The functions in the list below are implemented in the present system. 

40 (a) 'Open' function 

This function allows the WEB client to open a connection with a WEB proxy FCM. The function prototype is defined 
as follows: 

45 Status WEBProxy::Open( 

in ProtocolType protocol 
in short client__buffer_size, 
in OperationCode opCode, 

50 

out long cid, 

out short proxy_buffer_size. 
) 

55 

'Status' is the type of the function return value. 
The following parameters are used: 
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protocol: this parameter, set by the WEB client, defines the protocol (HTTP...) dedicated to the session the 
WEB client wants to open. 

client_buffer_size: this parameter, set by the WEB client, gives the maximum size of a message accepted by 
the WEB client, in other words the size of its message buffer. The WEB proxy FCM will use this parameter to 
define the size of messages sent to the client. Data to be sent by the WEB Proxy FCM will be split in a number 
of data blocks, depending on this parameter. 

opCode: this parameter is a code the WEB proxy FCM will use to forward an incoming response from the inter- 
net to the WEB client. This operation code identifies a function of the WEB client which the WEB Proxy FCM 
has to call to forward a response to the client. This parameter is set by the WEB client. In the present case, the 
value of the opCode identifies the function 'Receive'. The operation code uniquely identifies a function within a 
software element. The unique address of a function in the network thus comprises the 'SEID* identifier and the 
operation code. 

cid: this parameter is an identifier of the connection between the WEB client and the WEB proxy FCM. It is 
defined by the WEB Proxy FCM. It allows several connections from the same software component client to be 
opened in parallel (with the same WEB Proxy FCM or with other WEB Proxy FCMs) and also permits to match 
a response from the internet with a request. 

proxy_buffer_size: this parameter, returned by the WEB Proxy FCM, indicates the maximum size (in bytes) 
of a message accepted by the WEB proxy FCM. The WEB client will use this parameter to determine the size 
of messages, for example requests, sent by the WEB client to the WEB Proxy FCM. 

After reception of the 'Open' function from a WEB client, the WEB Proxy FCM will return, along with the parameters 
above, one of the following status values: 

'0' in case of successful session opening, 

*1* in case of resource allocation error, 

'2' if the protocol type is not supported by the WEB client 

(b) 'Close* function 

This function enables a WEB client to close a previously opened connection with a WEB Proxy FCM, identified by 
the 'cid' parameter. The function prototype is defined as follows: 

Status WEBProxy::Open( 

in long cid 
) 

The only parameter is the 'cid' parameter, i.e. the identifier of this connection with the WEB proxy FCM. 
The WEB Proxy FCM acknowledges with one of the following status values: 

0: The connection has been closed successfully, 

1 : The transmitted value of the 'cid' parameter is unknown. 

(c) 'Send' function 

This function is called by a WEB client to send a request to a WEB server using the protocol (HTTP...) previously 
defined by the 'Open' function call. The function prototype is defined as follows: 
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Status WEBProxy::Send( 

in long cid, 

in FileLoc where, 

in sequence <byte> web_data, 

) 

In addition to the already defined 'cid' parameter, the function's parameters are the following: 

where: this parameter, determined by the calling software element, indicates if the message is the first mes- 
sage, an intermediate message or the last message in a sequence of messages. More than one message may 
be required to call this function, since the amount of data transmitted in the function call may be too great for 
the buffer of the WEB Proxy FCM to handle in one single message. 

web_data: this parameter contains a part or the entire request according to the WEB "application" protocol 
used through the connection identified by the 'cid* parameter. 

Upon receiving the function call, the WEB Proxy FCM acknowledges with one of the following status values: 

'0' if the message was processed successfully, 

T if the size of the "webjdata' exceeds the fixed maximum size, 

'2' if it is impossible to process this message, 

*3' if the transmitted value of the 'cid' parameter is unknown to the WEB Proxy FCM. 

In case of error, the WEB client decides whether or not to close the connection or to send again the previous mes- 
sage. 

(d) 'Receive' function 

This is the prototype of the function implemented in the WEB client which allows the WEB proxy FCM to forward to 
the WEB client an incoming response according to the WEB application protocol. 
The function prototype is defined as follows: 

Status WEBProxy::Receive( 
in long cid, 
in FileLoc where, 
in sequence <byte> web_data, 
) 

In addition to the parameters already defined, the following parameter is used by the present function: 

web_data: contains a part or the entire response according to the WEB "application" protocol used through 
the connection identified by the 'cid' parameter. 

Following the call by the WEB Proxy server, the WEB client acknowledges with one of the following status values: 

'0' if the message was processed successfully. 

'1 ' if the size of data exceeds the fixed maximum size, 

'2' if it is impossible for the WEB client to process this message, 

'3' if the WEB client does not recognize the value of the 'cid' parameter. 

In case of error, the WEB Proxy FCM does not react. It is up to the WEB client to decide whether it maintains the 
connection or not. 

(e) 'GetCapability' function 
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This function, callable by the WEB client, returns the list of protocols which the WEB Proxy FCM supports. 
The function prototype is the following: 

Void WEBProxy::GetCapability( 
5 out sequence (ProtocolType) ProtocolList 

) 

The sole parameter of the function is 'ProtocolList, which is the list of WEB application protocols which are available 
through the FCM. More than one protocol may be supported by the WEB Proxy FCM. 

10 

Figure 3 gives an example of a typical message exchange between a WEB client and a WEB Proxy FCM. At the level 
of the Message Passing System, a function call can trigger messages in two directions: a first message from the calling 
software element to the called software element with 'in-bound' parameters sent to this called software element, and a 
second message in the inverse direction, for shuttling back 'out-bound' parameters, if required. 

15 The 'Open' function, as illustrated in figure 3, gives rise to a first message from the WEB client to the WEB Proxy FCM. 
This message informs the WEB Proxy FCM of the protocol which will be used over the connection which is being 
opened, and of the size of the buffer which the WEB client allocates for return messages for that particular connection. 
Buffer sizes may be different from connection to connection. The WEB client also transmits the operation code of the 
Receive function, which the WEB Proxy FCM has to use to call the Receive function at the WEB client. At the Message 

20 Passing System level, the WEB client also transmits its own identifier 'SEID'. 

Assuming correct reception and processing, the WEB Proxy FCM responds by the return code '0' to indicate successful 
processing, sends a 'cid' value to identify the connection, and also transmits its own buffer size for further communica- 
tion. 

Once the connection open, the Web client proceeds to send a request to a WEB server, using the HTTP protocol. 
25 According to the example of figure 4, this request holds in a single message, which contains the connection identifier 
cid, the request under HTTP format, and the 'End' parameter. The WEB Proxy FCM acknowledges proper receipt, and 
forwards the request over the internet via its IP stack and modem. 

The WEB server will respond with the requested data and transmit it to the WEB Proxy FCM. Since in the present exam- 
ple, the quantity of data is far beyond the buffer capacity of the WEB client, the WEB Proxy FCM splits the data into 

30 messages of appropriate size. The WEB Proxy FCM sends a first data block as a parameter within the Receive function 
call, using the operation code previously obtained from the WEB client, appended to the 'SEID' identifier of the WEB 
client. It uses 'START as a parameter. Further messages are only sent after acknowledgment of receipt by the WEB 
client, to give it the time to process the received data and to empty its buffer. After having received the last data block, 
the WEB client closes the connection using the Close function. The WEB Proxy FCM answers by a last acknowledg- 

35 ment of receipt. 

Lastly, according to the present embodiment, the configuration of the WEB Proxy FCM, for instance of the modem con- 
nection, is carried out directly by the user through a graphical interface provided by the Device Control Module which 
manages the WEB Proxy FCM. There is no specific application programmable interface for this task, which can be car- 
ried out using the data driven interaction (DDI) mechanism provided by the HAVi specification. 

40 

Glossary: 

base AV device (BAV) 

45 [0034] A HAVi-compliant device containing HAVi SDD data but not running any of the software elements of the HAVi 
Architecture. 

controller 

so [0035] A device which controls other devices. An IAV or FAV device, 
data driven interaction (DDI) 

[0036] A HAVi mechanism allowing control of software elements, eg DCMs, via user interface elements such as but- 
55 tons and icons. 
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[0037] A software entity which renders DDI elements and handles user interaction. 
s DDI element 

[0038] The DDI encoding of a user interface element. 
DDI protocol 

10 

[0039] The HAVi messages supporting data driven interaction, 
device 

is [0040] A physical entity attached to the home network, examples are video players, recorders, cameras, CD and DVD 
players, set-top boxes, DTV receivers, and PCs. 

device control application 

20 [0041] A HAVi software element allowing user control of a specific device (and its functional components). Installed 
on request and possibly on a different controller than the one on which the DCM is installed. 

device control module (DCM) 

25 [0042] A HAVi software element providing an interface for controlling general functions of a device. 

DCM code unit 

[0043] A HAVi bytecode unit to be loaded and installed on a FAV, or a proprietary code unit to be installed on a FAV 
30 or IAV Installation of a DCM code unit results in one DCM and one or more FCMs and possibly one device control appli- 
cation. 

embedded DCM 

35 [0044] A DCM implemented in native (i.e., platform dependent) code. Embedded DCMs typically run on IAV devices, 
full AV device (FAV) 

[0045] A HAVi-compliant device which runs the software elements of the HAVi Architecture including a HAVi bytecode 
40 runtime. 

functional component 

[0046] An abstraction within the HAVi Architecture that represents a group of related functions associated with a 
45 device. For example a DTV receiver may consist of several functional components: tuner, decoder, audio amplifier, etc. 

functional component module (FCM) 

[0047] A HAVi software element providing an interface for controlling a specific functional component of a device. 

50 

global unique ID 
(GUID) 

55 [0048] A 64-bit quantity used to uniquely identify an IEEE 1394 device. Consists of a 24-bit company ID (obtained 
from the 1394 Registration Authority Committee) and a 40-bit serial number assigned by the device manufacturer. The 
GUID is stored in a device's configuration ROM and is persistent over 1394 network resets. 
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[0049] The HAVi Architecture comprises the messaging model, control model, device model, and execution environ- 
ment defined in this document. 

5 

HAVI bytecode 

[0050] A portable code representation used by uploaded DCMs and possibly by applications. FAV devices contain a 
runtime environment for loading and executing HAVi bytecode. HAVI bytecode is not yet specified but will be selected 
w from existing candidates. 

HAVi-compliant device 

[0051] A device supporting IEEE 1394, IEC 61883 and conforming to the HAVi Architecture specification for an FAV, 
15 IAV or BAV device. 

HAVi level 1 interoperability 

[0052] Refers to the features provided by lAVs and embedded DCMs. 

20 

HAVi level 2 interoperability 

[0053] Refers to the features provided by FAVs and uploaded DCMs. 
25 HAVi SDD data 

[0054] Self Describing Device (SDD) data is stored in the IEEE 1212 Configuration ROM found on 1394 devices. HAVi 
specifies SDD data items that may be used for DDI elements or uploaded DCMs. 

30 HAVi unique ID (HUID) 

[0055] A unique identification of devices and their functional components. Persistent over changes in network config- 
uration (i.e., device plug-in or plug-out). 

35 home network 

[0056] The home network is the generic name used to define the communications infrastructure within the home. This 
name is used as an abstraction from the physical media and associated protocols. A home network supports both the 
exchange of control information and the exchange of AV content. 

40 

intermediate AV device (IAV) 

[0057] A HAVi-compliant device which runs the software elements of the HAVi Architecture but does not include a 
HAVi bytecode runtime environment. 

45 

legacy AV device (LAV) 
[0058] A non HAVi-compliant device. 
so software element 

[0059] A HAVi object. A software element responds to a set of messages specified by the API for that element, 
software element ID (SEID) 

55 

[0060] A 80-bit value used to identify software elements. Not guaranteed to be persistent over changes in network 
configuration (i.e., device plug-in or plug-out). 
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uploaded DCM 

[0081] A DCM implemented in HAVi bytecode. Uploaded DCMs run only on FAV devices. 
s Claims 

1. Communication method in a home network comprising at least two devices connected to a communication bus, 
characterized in that, a first device including an internet application and a second device including means for con- 
necting to the internet, said second device being able to manage at least one internet application protocol, said 

10 method comprises the steps of 

sending a request from said first device to said second device for opening a connection between said first and 
second devices, wherein said request contains an internet application protocol identifier to identify the internet 
application protocol to be used over said connection; 
is - sending an internet protocol request under the format of said internet application protocol from said first device 
to said second device; 

forwarding said internet protocol request from said second device to an internet server; 

upon receipt, transferring an response from said internet server to said first device through said second device 

over said communication bus. 

20 

2. Method according to claim 1 , characterized in that said request includes the message buffer size allocated to said 
connection by said first device. 

3. Method according to claims 1 or 2, characterized in that said acknowledgment of receipt includes the message 
25 buffer size allocated to said connection by said second device. 

4. Method according to one of the claims 2 or 3, characterized in that a sending device splits data to be sent to a 
receiving device into messages of a size which is smaller than the size of the message buffer of the receiving 
device. 

30 

5. Method according to one of the claims 1 to 4, further including the step of sending, by said first device to said sec- 
ond device, a request for a list of internet application protocols supported by said second device. 

6. Method according to one of the claims 1 to 5, further comprising the step of sending, by said first device to said 
35 second device, an address of a function of said first device, said second device sending internet responses to said 

first device as parameters of a call of said function. 

7. Method according to one of the claims 1 to 6, wherein said second device attributes a connection identifier to a con- 
nection requested by said first device, said connection identifier being sent from said first device to said second 

40 device as acknowledgment of receipt for said request for opening said connection. 

8. Method according to claim 7, wherein said first and second devices systematically use said connection identifier as 
parameter for function calls by said first device to said second device or vice-versa. 

45 9. Home communication network comprising devices connected by a communication bus, said network being charac- 
terized in that it comprises at least one device including a WEB interface, said device comprising an IP stack and 
a connection to the internet, said at least one device comprising an application programmable interface for making 
said WEB interface accessible to software element clients of other devices in said network 

so 1 0. Device in a home communication network characterized in that it comprises a WEB interface, said device also com- 
prising an IP stack and a connection to the internet, said at least one device comprising an application programma- 
ble interface for making said WEB interface accessible to software element clients of other devices in said network. 
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